草庐IT

STM32的HAL库的IIC OLED驱动

全部标签

linux - 针对共享库的内存写保护

我突然对一件事很好奇。共享库,如glibc(在Linux中)、kernel32.dll(在Windows中)在进程之间物理共享。但是,由于这些库位于(映射)在用户虚拟内存地址空间中,我认为恶意进程可能会将共享库内存区域的访问属性更改为可写,并弄乱所有内容,从而使共享它们的所有其他进程崩溃。我在Linux中进行了以下实验,系统没有崩溃。下面是我的测试源代码。meltdown@ubuntu:/tmp$cata.c#include#include#includeintg=0;intmain(intargc,char*argv[]){int*a=(int*)strtoul(argv[1],0,

windows - 如何在 win32 控制台上解析 "printf"而不是 "_printf"的符号?

测试平台是windows32bit。所以基本上我想在这些命令中汇编+链接一段汇编代码:nasm-fwin32test.scltest.obj/linkmsvcrt.lib它说:errorLNK2001:unresolvedexternalsymbolprintf在我的代码中,我确实有这样的函数调用:callprintf所以我把这些都改成了call_printf而且有效。我对windows编程不熟悉,请问有什么方法可以解析printf的外部符号吗?因为我在做一些自动转换的任务,转换所有以_开头的函数调用应该很繁琐...谁能给我一些帮助..?谢谢! 最佳答案

windows - windows中将64位地址截断为32位地址时,为什么要保证高33位为0,高32位不为0?

我一直在通过JeffreyRichter的C/C++阅读Windows,并在有关将32位应用程序移植到64位环境的Windows内存架构的章节中看到以下片段。Ifthesystemcouldsomehowguaranteethatnomemoryallocationswouldeverybemadeabove0x00000000'7FFFFFFF,theapplicationwouldworkfine.Truncatinga64bitaddresstoa32bitaddresswhenthehigh33bitsare0causesnoproblemwhatsoever.我无法理解为什么

c++ - 使用 Win32/C++ API 更改 Windows 7 墙纸(操作未实现异常)

以下代码适用于Windows8.1(已测试)但不适用于Windows7。std::wstringloc=L"C:\\Users\User\\Desktop\\wallpaper.jpg";BOOLret=SystemParametersInfo(SPI_SETDESKWALLPAPER,0,(PVOID)loc.c_str(),SPIF_UPDATEINIFILE);当我在Windows7上运行该程序时,出现以下异常:First-chanceexceptionat0x76E3C41F(KernelBase.dll)inMyApp.exe:0xC0000002:Therequestedo

在网络驱动器上安装目录时 Windows Installer 无法访问网络位置

我有一个在VisualStudio2010中构建的C++Windows应用程序,它带有一个安装项目来创建一个.msi,当用户拥有本地MyDocuments文件夹时安装正常,但当他们的MyDocuments文件夹位于网络驱动器上。在本地安装时,安装程​​序会在其MyDocuments文件夹中创建Project和Data文件夹,但是当我尝试安装到系统时我的文档在网络位置,.msi失败并显示无法访问网络位置错误消息。查看安装程序日志文件,似乎失败发生在安装程序创建描述Project和Data目录的属性时,而不是在尝试创建和填充这些目录时目录。有人知道我可以如何避免、变通或从该错误中恢复吗?现

c# - 在 32 位机器上部署 64 位 C# winform 应用程序

我已经在64位机器上使用VS2012开发了一个C#winform应用程序,现在我想将它部署到32位机器上,但是我得到了“...不是有效的win32应用程序”形式的错误"每当我尝试在32位机器上安装和运行exe文件时。请建议我解决这种情况的最佳方法。谢谢! 最佳答案 听起来该项目是专门为x64编译的。纯.NET项目可以而且应该编译为“任何CPU”,这意味着它们将在x86和x64上运行。这通常是默认值。http://blogs.microsoft.co.il/sasha/2012/04/04/what-anycpu-really-mea

c - 从内核驱动程序到达内核 session 空间

我正在编写一个内核驱动程序,它应该读取(在某些情况下还写入)内核session空间(win32k.sys)中的一些内存地址。我读过另一个主题,例如在Windbg中,我应该将上下文更改为随机用户进程以读取内核session空间的内存(使用.process/p)。我怎样才能在内核驱动程序中做到这一点?我应该创建一个与驱动程序通信的用户进程(这是我现在的想法,但我希望有更好的解决方案)还是有更简单的解决方案? 最佳答案 session空间未映射到系统地址空间(驱动程序共享,如果未附加到任何进程)。这就是为什么您在访问win32k时出现蓝屏

c++ - Windows XP中如何判断一个驱动器是否支持硬链接(hard link)?

我找到了以下解决方案来确定驱动器是否支持硬链接(hardlink):CStringstrDrive=_T("C:\\");DWORDdwSysFlags;if(GetVolumeInformation(strDrive,NULL,0,NULL,NULL,&dwSysFlags,NULL,0)){if((dwSysFlags&FILE_SUPPORTS_HARD_LINKS)!=0){//Hardlinkscanbecreatedonthespecifieddrive.}else{//Hardlinkscannotbecreatedonthespecifieddrive.}}然而,根据M

windows - 获取引导分区驱动器名称

关闭。这个问题不符合StackOverflowguidelines。它目前不接受答案。这个问题似乎与aspecificprogrammingproblem,asoftwarealgorithm,orsoftwaretoolsprimarilyusedbyprogrammers无关。如果您认为该问题与anotherStackExchangesite上的主题相关,您可以发表评论以说明可以在哪里回答该问题。关闭7年前。Improvethisquestion我需要从bat脚本中获取引导分区的驱动器名称。我使用reagentc.exe/info获取引导分区号,如下所示:WindowsRE位置:\

windows - 无法使用 powershell 从 32 位版本的 win2008 读取 64 位注册表项

我尝试使用powershell从32位Windows2008读取64位版本的WindowsServer2008r2上的以下注册表项,但该值显示为空白并且不返回任何值。可以帮助我了解如何从32位服务器读取64位注册key吗?$line="WIN-QENOBBC64B8"$regkey=[Microsoft.Win32.RegistryKey]::OpenRemoteBaseKey([Microsoft.Win32.RegistryHive]::LocalMachine,$line)$ref=$regKey.OpenSubKey("SOFTWARE\Microsoft\MicrosoftS